草庐IT

xml - Nmap::Parser,大文件的段错误

全部标签

ruby - 在 Ruby 中,为什么在启动 irb 之后出现 foo.nil?说未定义的错误,@foo.nil?给出 "true"和 @@wah.nil?又报错了?

在Ruby1.8.7和1.9.2中相同:$irbruby-1.8.7-p302>foo.nil?NameError:undefinedlocalvariableormethod`foo'for#from(irb):1ruby-1.8.7-p302>@bar.nil?=>trueruby-1.8.7-p302>@@wah.nil?NameError:uninitializedclassvariable@@wahinObjectfrom(irb):3为什么实例变量与局部变量和类变量的处理方式不同? 最佳答案 在Ruby中,大多数未初始化

ruby - Rspec 模拟错误 : wrong number of arguments

我正在尝试使用Rspec对StripeAPI进行stub,但我遇到了一个问题。这是我的代码的样子:Stripe::Customer.should_receive(:create).with(any_args).and_raise(Stripe::CardError)这是我遇到的错误:Failure/Error:Stripe::Customer.should_receive(:create).with(any_args).and_raise(Stripe::CardError)ArgumentError:wrongnumberofarguments(0for3..6)

ruby - Sinatra:提供普通旧文件的正确方法是什么?

这是有效的,但它是在黑暗中刺伤。我对Ruby知之甚少。为给定资源提供普通旧文件的公认方式是什么?get'/xyz'doFile.read'abc.html'end 最佳答案 您可以使用set:public来指定静态文件的目录。然后,您可以使用send_file()提供文件,例如:get'/static_file'dosend_file('my_static_file')end 关于ruby-Sinatra:提供普通旧文件的正确方法是什么?,我们在StackOverflow上找到一个类似的

ruby-on-rails - 如何在 Ruby 中从下到上读取文件?

我一直在为Rails应用开发日志查看器,发现我需要从下到上阅读大约200行的日志文件,而不是默认的从上到下阅读。日志文件可能会变得非常大,所以我已经尝试并排除了IO.readlines("log_file.log")[-200..-1]方法。有没有其他方法可以在不需要插件或gem的情况下在Ruby中反向读取文件? 最佳答案 执行此操作且适用于大型文件的唯一正确方法是从末尾一次读取n个字节,直到获得所需的行数。这基本上就是Unixtail的工作方式。IO#tail(n)的示例实现,它将最后的n行作为Array返回:classIOTAI

ruby-on-rails - 模拟 rspec 中的错误/异常(不仅仅是它的类型)

我有一段代码是这样的:defsome_methodbegindo_some_stuffrescueWWW::Mechanize::ResponseCodeError=>eife.response_code.to_i==503handle_the_situationendendend我想测试ife.response_code.to_i==503部分发生了什么。我可以模拟do_some_stuff以抛出正确类型的异常:whatever.should_receive(:do_some_stuff).and_raise(WWW::Mechanize::ResponseCodeError)但是我

ruby-on-rails - 在 Ruby 中返回 true 或错误消息

我想知道编写这样的函数是好的还是坏的形式。deftest(x)ifx==1returntrueelsereturn"Error:xisnotequaltoone."endend然后为了使用它,我们做这样的事情:result=test(1)ifresult!=trueputsresultendresult=test(2)ifresult!=trueputsresultend它只显示第二次调用测试的错误消息。我正在考虑这样做,因为在一个Rails项目中,我在我的Controller代码中工作,我调用模型的实例方法,如果出现问题,我希望模型将错误消息返回给Controller和Control

ruby - 将 Ruby 打包成可移植的可执行文件

长期以来,我一直在努力寻找一个好的解决方案:是否有可靠的方法将ruby​​安装到可在该平台上移植的文件夹中?我想要一个文件夹,我可以轻松地将其复制到我正在制作的发行版中,这样我就可以“随时随地”拥有一个ruby​​环境。如果我需要编译源代码和其他东西,那很好,只要我最终安装了可移植的ruby​​安装即可。我找到了一些试图解决这个问题的资源,但没有一个让我满意。PortableRubyonRailsenvironmenthttp://hcettech.blogspot.pt/2012/05/windows-portable-rails-development.html对我来说,这是Rub

ruby-on-rails - 如何将本地文件上传到 Carrierwave 模型?

我使用Carrierwave来处理图像上传,但我没有使用表单,而是使用服务器中的本地文件。我怎样才能让它工作?@user=User.firstimage_path="/tmp/pic-s7b28.jpg"@user.image=image_path@user.save! 最佳答案 @user=User.firstimage_path="/tmp/pic-s7b28.jpg"@user.image=File.open(image_path)@user.save!您可以查看carrierwavereadme中的示例

ruby-on-rails - 如何在 Capybara 和 RSpec 中测试 CSV 文件下载?

Controller中的内容如下:respond_todo|format|format.csv{send_dataas_csv,type:'text/csv'}end在规范中:click_link'DownloadCSV'page.driver.browser.switch_to.alert.acceptexpect(page).tohave_contentcsv_data但这行不通:Failure/Error:page.driver.browser.switch_to.alert.acceptSelenium::WebDriver::Error::NoAlertPresentErro

ruby-on-rails - 处理超时错误

使用超时后:status=Timeout::timeout(5){#Somethingthatshouldbeinterruptedifittakestoomuchtime...}我收到这个超时错误:/Users/galharth/.rvm/rubies/ruby-1.9.2-p136/lib/ruby/1.9.1/net/http.rb:644:in`initialize':executionexpired(Timeout::Error)from/Users/galharth/.rvm/rubies/ruby-1.9.2-p136/lib/ruby/1.9.1/net/http.rb